- Low-Power Advanced BiCMOS Technology
- Free-Running CLKA and CLKB Can Be Asynchronous or Coincident
- $64 \times 36$ FIFO Buffering Data From Port A to Port B
- Mailbox-Bypass Registers in Each Direction
- Dynamic Port-B Bus Sizing of 36 Bits (Long Word), 18 Bits (Word), and 9 Bits (Byte)
- Selection of Big- or Little-Endian Format for Word and Byte Bus Sizes
- Three Modes of Byte-Order Swapping on Port B
- Programmable Almost-Full and
Almost-Empty Flags
- Microprocessor Interface Control Logic
- $\overline{\mathrm{FF}}$ and $\overline{\mathrm{AF}}$ Flags Synchronized by CLKA
- $\overline{\mathrm{EF}}$ and $\overline{\mathrm{AE}}$ Flags Synchronized by CLKB
- Passive Parity Checking on Each Port
- Parity Generation Can Be Selected for Each Port
- Supports Clock Frequencies up to 67 MHz
- Fast Access Times of 10 ns
- Package Options Include 120-Pin Thin Quad Flat (PCB) and 132-Pin Quad Flat (PQ) Packages


## description

The SN74ABT3613 is a high-speed, low-power BiCMOS clocked FIFO memory. It supports clock frequencies up to 67 MHz and has read-access times as fast as 10 ns . A $64 \times 36$ dual-port SRAM FIFO in this device buffers data from port A to port B. The FIFO has flags to indicate empty and full conditions and two programmable flags (almost full and almost empty) to indicate when a selected number of words is stored in memory. FIFO data on port B can be output in 36-bit, 18-bit, and 9-bit formats, with a choice of big- or little-endian configurations. Three modes of byte-order swapping are possible with any bus-size selection. Communication between each port can bypass the FIFO via two 36-bit mailbox registers. Each mailbox register has a flag to signal when new mail has been stored. Parity is checked passively on each port and can be ignored if not desired. Parity generation can be selected for data read from each port.

The SN74ABT3613 is a clocked FIFO, which means each port employs a synchronous interface. All data transfers through a port are gated to the low-to-high transition of a continuous (free-running) port clock by enable signals. The continuous clocks for each port are independent of one another and can be asynchronous or coincident. The enables for each port are arranged to provide a simple interface between microprocessors and/or buses controlled by a synchronous interface.
The full flag ( $\overline{\mathrm{FF}}$ ) and almost-full ( $\overline{\mathrm{AF}}$ ) flag of a FIFO are two-stage synchronized to the port clock that writes data to its array. The empty flag ( $\overline{\mathrm{EF}}$ ) and almost-empty ( $\overline{\mathrm{AE}}$ ) flag of a FIFO are two-stage synchronized to the port clock that reads data from its array.
The SN74ABT3613 is characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.
For more information on this device family, see the following application reports:

- FIFO Mailbox-Bypass Registers: Using Bypass Registers to Initialize DMA Control (literature number SCAA007)
- Advanced Bus-Matching/Byte-Swapping Features for Internetworking FIFO Applications (literature number SCAA014)
- Parity-Generate and Parity-Check Features for High-Bandwidth-Computing FIFO Applications (literature number SCAA015)
- Internetworking the SN74ABT3614 (literature number SCAA018)
- Metastability Performance of Clocked FIFOs (literature number SCZA004)

Please be aware that an important notice concerning availability, standard warranty, and use in critical applications of Texas Instruments semiconductor products and disclaimers thereto appears at the end of this data sheet.


NC - No internal connection


NC - No internal connection
† Uses Yamaichi socket IC51-1324-828

## functional block diagram



## Terminal Functions

| TERMINAL NAME | 1/0 | DESCRIPTION |
| :---: | :---: | :---: |
| A0-A35 | I/O | Port-A data. The 36-bit bidirectional data port for side A. |
| $\overline{\mathrm{AE}}$ | $\begin{gathered} \mathrm{O} \\ \text { (port B) } \end{gathered}$ | Almost-empty flag. Programmable almost-empty flag synchronized to CLKB. $\overline{\mathrm{AE}}$ is low when the number of 36 -bit words in the FIFO is less than or equal to the value in offset register X. |
| $\overline{\mathrm{AF}}$ | $\begin{gathered} \mathrm{O} \\ (\text { port A) } \end{gathered}$ | Almost-full flag. Programmable almost-full flag synchronized to CLKA. $\overline{\mathrm{AF}}$ is low when the number of 36 -bit empty locations in the FIFO is less than or equal to the value in offset register $X$. |
| B0-B35 | I/O | Port-B data. The 36-bit bidirectional data port for side B. |
| $\overline{\mathrm{BE}}$ | 1 | Big-endian select. Selects the bytes on port B used during byte or word FIFO reads. A low on $\overline{\mathrm{BE}}$ selects the most-significant bytes on B0-B35 for use, and a high selects the least-significant bytes. |
| CLKA | I | Port-A clock. CLKA is a continuous clock that synchronizes all data transfers through port A and can be asynchronous or coincident to CLKB. $\overline{\mathrm{FF}}$ and $\overline{\mathrm{AF}}$ are synchronized to the low-to-high transition of CLKA. |
| CLKB | 1 | Port-B clock. CLKB is a continuous clock that synchronizes all data transfers through port B and can be asynchronous or coincident to CLKA. Port-B byte swapping and data-port-sizing operations are also synchronous to the low-to-high transition of CLKB. $\overline{\mathrm{EF}}$ and $\overline{\mathrm{AE}}$ are synchronized to the low-to-high transition of CLKB. |
| $\overline{\text { CSA }}$ | 1 | Port-A chip select. $\overline{\mathrm{CSA}}$ must be low to enable a low-to-high transition of CLKA to read or write data on port A. The A0-A35 outputs are in the high-impedance state when CSA is high. |
| $\overline{\text { CSB }}$ | 1 | Port-B chip select. $\overline{\mathrm{CSB}}$ must be low to enable a low-to-high transition of CLKB to read or write data on port B . The B0-B35 outputs are in the high-impedance state when $\overline{\mathrm{CSB}}$ is high. |
| $\overline{\mathrm{EF}}$ | $\underset{(\text { port B) }}{\mathrm{O}}$ | Empty flag. $\overline{\mathrm{EF}}$ is synchronized to the low-to-high transition of CLKB. When $\overline{\mathrm{EF}}$ is low, the FIFO is empty and reads from its memory are disabled. Data can be read from the FIFO to the output register when $\overline{\mathrm{EF}}$ is high. $\overline{\mathrm{EF}}$ is forced low when the device is reset and is set high by the second low-to-high transition of CLKB after data is loaded into empty FIFO memory. |
| ENA | 1 | Port-A enable. ENA must be high to enable a low-to-high transition of CLKA to read or write data on port A. |
| ENB | 1 | Port-B enable. ENB must be high to enable a low-to-high transition of CLKB to read or write data on port B. |
| $\overline{\mathrm{FF}}$ | $\begin{gathered} \mathrm{O} \\ \text { (port A) } \end{gathered}$ | Full flag. $\overline{\mathrm{FF}}$ is synchronized to the low-to-high transition of CLKA. When $\overline{\mathrm{FF}}$ is low, the FIFO is full and writes to its memory are disabled. $\overline{\mathrm{FF}}$ is forced low when the device is reset and is set high by the second low-to-high transition of CLKA after reset. |
| $\begin{aligned} & \text { FS1 } \\ & \text { FS0 } \end{aligned}$ | 1 | Flag offset selects. The low-to-high transition of $\overline{\mathrm{RST}}$ latches the values of FS0 and FS1, which selects one of four preset values for the $\overline{\mathrm{AE}}$ flag and $\overline{\mathrm{AF}}$ flag offset. |
| MBA | 1 | Port-A mailbox select. A high level on MBA chooses a mailbox register for a port-A read or write operation. When the A0-A35 outputs are active, mail2 register data is output. |
| $\overline{\text { MBF1 }}$ | 0 | Mail1 register flag. $\overline{\text { MBF1 }}$ is set low by the low-to-high transition of CLKA that writes data to the mail1 register. Writes to the mail1 register are inhibited while $\overline{\mathrm{MBF}}$ is low. $\overline{\text { MBF1 }}$ is set high by a low-to-high transition of CLKB when a port-B read is selected and both SIZ1 and SIZ0 are high. $\overline{\text { MBF1 }}$ is set high when the device is reset. |
| $\overline{\text { MBF2 }}$ | 0 | Mail2 register flag. $\overline{\text { MBF2 }}$ is set low by the low-to-high transition of CLKB that writes data to the mail2 register. Writes to the mail2 register are inhibited while $\overline{\mathrm{MBF2}}$ is low. $\overline{\mathrm{MBF}}$ is set high by a low-to-high transition of CLKA when a port-A read is selected and MBA is high. MBF2 is set high when the device is reset. |
| ODD/EVEN | 1 | Odd/even parity select. Odd parity is checked on each port when ODD/EVEN is high and even parity is checked when ODD/EVEN is low. ODD/EVEN also selects the type of parity generated for each port if parity generation is enabled for a read operation. |
| $\overline{\text { PEFA }}$ | $\underset{(\text { port A) }}{\mathrm{O}}$ | Port-A parity error flag. When any byte applied to terminals A0-A35 fails parity, $\overline{\text { PEFA }}$ is low. Bytes are organized as A0-A8, A9-A17, A18-A26, and A27-A35, with the most-significant bit of each byte serving as the parity bit. The type of parity checked is determined by the state of ODD/EVEN. <br> The parity trees used to check the A0-A35 inputs are shared by the mail2 register to generate parity if parity generation is selected by PGA; therefore, if a mail2 read with parity generation is set up by having CSA low, ENA high, W/RA low, MBA high, and PGA high, the $\overline{\text { PEFA }}$ flag is forced high, regardless of the state of the A0-A35 inputs. |

## Terminal Functions (Continued)

| TERMINAL NAME | 1/0 | DESCRIPTION |
| :---: | :---: | :---: |
| $\overline{\text { PEFB }}$ | $\begin{gathered} \mathrm{O} \\ (\text { port } B) \end{gathered}$ | Port-B parity error flag. When any valid byte applied to terminals B0-B35 fails parity, $\overline{\text { PEFB }}$ is low. Bytes are organized as B0-B8, B9-B17, B18-B26, and B27-B35 with the most-significant bit of each byte serving as the parity bit. A byte is valid when it is used by the bus size selected for port B . The type of parity checked is determined by the state of ODD/EVEN. <br> The parity trees used to check the B0-B35 inputs are shared by the mail1 register to generate parity if parity generation is selected by PGB; therefore, if a mail1 read with parity generation is set up by having $\overline{C S B}$ low, ENB high, W/ $\bar{R} B$ low, SIZ1 and SIZO high, and PGB high, the $\overline{\text { PEFB }}$ flag is forced high, regardless of the state of the B0-B35 inputs. |
| PGA | 1 | Port-A parity generation. Parity is generated for data reads from the mail2 register when PGA is high. The type of parity generated is selected by the state of ODD/EVEN. Bytes are organized as A0-A8, A9-A17, A18-A26, and A27-A35. The generated parity bits are output in the most-significant bit of each byte. |
| PGB | 1 | Port-B parity generation. Parity is generated for data reads from port B when PGB is high. The type of parity generated is selected by the state of ODD/EVEN. Bytes are organized as B0-B8, B9-B17, B18-B26, and B27-B35. The generated parity bits are output in the most-significant bit of each byte. |
| $\overline{\mathrm{RST}}$ | 1 | Reset. To reset the device, four low-to-high transitions of CLKA and four low-to-high transitions of CLKB must occur while $\overline{\operatorname{RST}}$ is low. This sets the $\overline{\mathrm{AF}}, \overline{\mathrm{MBF}}$, and $\overline{\mathrm{MBF}}$ flags high and the $\overline{\mathrm{EF}}, \overline{\mathrm{AE}}$, and $\overline{\mathrm{FF}}$ flags low. The low-to-high transition of $\overline{\mathrm{RST}}$ latches the status of the FS1 and FS0 inputs to select $\overline{\mathrm{AF}}$ flag and $\overline{\mathrm{AE}}$ flag offset. |
| $\begin{aligned} & \text { SIZ0 } \\ & \text { SIZ1 } \end{aligned}$ | $\begin{gathered} \text { I } \\ \text { (port B) } \end{gathered}$ | Port-B bus size selects. The low-to-high transition of CLKB latches the states of SIZO, SIZ1, and $\overline{\mathrm{BE}}$, and the following low-to-high transition of CLKB implements the latched states as a port-B bus size. Port-B bus sizes can be long word, word, or byte. A high on both SIZ0 and SIZ1 accesses the mailbox registers for a port-B 36-bit write or read. |
| $\begin{aligned} & \text { SW0 } \\ & \text { SW1 } \end{aligned}$ | $\begin{gathered} \text { I } \\ \text { (port B) } \end{gathered}$ | Port-B byte swap selects. At the beginning of each long-word FIFO read, one of four modes of byte-order swapping is selected by SW0 and SW1. The four modes are no swap, byte swap, word swap, and byte-word swap. Byte-order swapping is possible with any bus-size selection. |
| W/RA | I | Port-A write/read select. W/ $\bar{R} A$ high selects a write operation and a low selects a read operation on port A for a low-to-high transition of CLKA. The A0-A35 outputs are in the high-impedance state when W/ $\bar{R} A$ is high. |
| W/RB | 1 | Port-B write/read select. W/ $\bar{R} B$ high selects a write operation and a low selects a read operation on port $B$ for a low-to-high transition of CLKB. The B0-B35 outputs are in the high-impedance state when W/RB is high. |

## detailed description

## reset

The SN74ABT3613 is reset by taking the reset ( $\overline{\text { RST }})$ input low for at least four port-A clock (CLKA) and four port-B clock (CLKB) low-to-high transitions. The reset input can switch asynchronously to the clocks. A device reset initializes the internal read and write pointers of each FIFO and forces $\overline{\mathrm{FF}}$ low, $\overline{\mathrm{EF}}$ low, $\overline{\mathrm{AE}}$ low, and the $\overline{\mathrm{AF}}$ high. A reset also forces the mailbox flags ( $\overline{\mathrm{MBF}}$, $\overline{\mathrm{MBF}}$ ) high. After a reset, $\overline{\mathrm{FF}}$ is set high after two low-to-high transitions of CLKA. The device must be reset after power up before data is written to its memory.
A low-to-high transition on the $\overline{\mathrm{RST}}$ input loads the $\overline{\mathrm{AF}}$ and $\overline{\mathrm{AE}}$ offset register $(\mathrm{X})$ with the value selected by the flag-select (FS0, FS1) inputs. The values that can be loaded into the register are shown in Table 1.

Table 1. Flag Programming

| FS1 | FS0 | $\overline{\text { RST }}$ | $\overline{\text { AF/AE FLAG }}$ <br> OFFSET REGISTER (X) |
| :---: | :---: | :---: | :---: |
| $H$ | $H$ | $\uparrow$ | 16 |
| $H$ | L | $\uparrow$ | 12 |
| L | H | $\uparrow$ | 8 |
| L | L | $\uparrow$ | 4 |

## FIFO write/read operation

The state of the port-A data (A0-A35) outputs is controlled by the port-A chip select ( $\overline{\mathrm{CSA}}$ ) and the port-A write/read select (W/ $\bar{R} A$ ). The A0-A35 outputs are in the high-impedance state when either $\overline{C S A}$ or $W / \bar{R} A$ is high. The A0-A35 outputs are active when both $\overline{\mathrm{CSA}}$ and $\mathrm{W} / \overline{\mathrm{R} A}$ are low. Data is loaded into the FIFO from the A0-A35 inputs on a low-to-high transition of CLKA when $\overline{C S A}$ is low, W/RA is high, ENA is high, MBA is low, and FFA is high (see Table 2).

Table 2. Port-A Enable Function Table

| $\overline{\text { CSA }}$ | W/伊A | ENA | MBA | CLKA | A0-A35 OUTPUTS | PORT FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| H | X | X | X | X | In high-impedance state | None |
| L | H | L | X | X | In high-impedance state | None |
| L | H | H | L | $\uparrow$ | In high-impedance state | FIFO write |
| L | H | H | H | $\uparrow$ | In high-impedance state | Mail1 write |
| L | L | L | L | X | Active, mail2 register | None |
| L | L | H | L | $\uparrow$ | Active, mail2 register | None |
| L | L | L | H | X | Active, mail2 register | None |
| L | L | H | H | $\uparrow$ | Active, mail2 register | Mail2 read (set $\overline{\text { MBF2 high) }}$ |

The state of the port-B data ( $\mathrm{B} 0-\mathrm{B} 35$ ) outputs is controlled by the port-B chip select ( $\overline{\mathrm{CSB}}$ ) and the port-B write/read select ( $\mathrm{W} / \overline{\mathrm{R}} \mathrm{B}$ ). The $\mathrm{B} 0-\mathrm{B} 35$ outputs are in the high-impedance state when either $\overline{\mathrm{CSB}}$ or $W / \overline{\mathrm{R}} \mathrm{B}$ is high. The B0-B35 outputs are active when both $\overline{C S B}$ and $W / \bar{R} B$ are low. Data is read from the FIFO to the B0-B35 outputs by a low-to-high transition of CLKB when $\overline{C S B}$ is low, $W / \bar{R} B$ is low, ENB is high, $\overline{\mathrm{EFB}}$ is high, and either SIZ0 or SIZ1 is low (see Table 3).

Table 3. Port-B Enable Function Table

| $\overline{\text { CSB }}$ | W/信B | ENB | SIZ1, SIZO | CLKB | B0-B35 OUTPUTS | PORT FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| H | X | X | X | X | In high-impedance state | None |
| L | H | L | X | X | In high-impedance state | None |
| L | H | H | One, both low | $\uparrow$ | In high-impedance state | None |
| L | H | H | Both high | $\uparrow$ | In high-impedance state | Mail2 write |
| L | L | L | One, both low | X | Active, FIFO output register | None |
| L | L | H | One, both low | $\uparrow$ | Active, FIFO output register | FIFO read |
| L | L | L | Both high | X | Active, mail1 register | None |
| L | L | H | Both high | $\uparrow$ | Active, mail1 register | Mail1 read (set MBF1 high) |

The setup- and hold-time constraints to the port clocks for the port-chip selects ( $\overline{\mathrm{CSA}}, \overline{\mathrm{CSB}}$ ) and write/read selects (W/RA, W/RB) are only for enabling write and read operations and are not related to high-impedance control of the data outputs. If a port enable is low during a clock cycle, the port chip select and write/read select can change states during the setup- and hold-time window of the cycle.

## synchronized FIFO flags

Each FIFO flag is synchronized to its port clock through two flip-flop stages. This is done to improve flag reliability by reducing the probability of metastable events on the output when CLKA and CLKB operate asynchronously to one another. $\overline{\mathrm{FF}}$ and $\overline{\mathrm{AF}}$ are synchronized to CLKA. $\overline{\mathrm{EF}}$ and $\overline{\mathrm{AE}}$ are synchronized to CLKB. Table 4 shows the relationship of each port flag to the level of FIFO fill.

Table 4. FIFO Flag Operation

| NUMBER OF 36-BIT <br> WORDS IN THE FIFO† | SYNCHRONIZED <br> TO CLKB |  | SYNCHRONIZED <br> TO CLKA |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\text { EF }}$ | $\overline{\mathbf{A E}}$ | $\overline{\mathbf{A F}}$ | $\overline{\text { FF }}$ |
| 0 | L | L | H | H |
| 1 to X | H | L | H | H |
| $(\mathrm{X}+1)$ to $[64-(\mathrm{X}+1)]$ | H | H | H | H |
| $(64-\mathrm{X})$ to 63 | H | H | L | H |
| 64 | H | H | L | L |

$\dagger X$ is the value in the $\overline{\mathrm{AE}}$ flag and $\overline{\mathrm{AF}}$ flag offset register.

## empty flag ( $\overline{E F}$ )

The FIFO $\overline{\mathrm{EF}}$ is synchronized to the port clock that reads data from its array (CLKB). When the empty flag is high, new data can be read to the FIFO output register. When the empty flag is low, the FIFO is empty and attempted FIFO reads are ignored. When reading the FIFO with a byte or word size on port B, $\overline{\mathrm{EF}}$ is set low when the fourth byte or second word of the last long word is read.
The FIFO read pointer is incremented each time a new word is clocked to the output register. A word written to the FIFO can be read to the FIFO output register in a minimum of three port-B clock (CLKB) cycles. An $\overline{E F}$ is low if a word in memory is the next data to be sent to the FIFO output register and two cycles of the port clock that reads data from the FIFO have not elapsed since the time the word was written. The FIFO EF is set high by the second low-to-high transition of CLKB and the new data word can be read to the FIFO output register in the following cycle.

A low-to-high transition on CLKB begins the first synchronization cycle of a write if the clock transition occurs at time $\mathrm{t}_{\mathrm{sk} 1}$, or greater, after the write. Otherwise, the subsequent clock cycle can be the first synchronization cycle (see Figure 9).

## full flag (FF)

The FIFO $\overline{\mathrm{FF}}$ is synchronized to the port clock that writes data to its array (CLKA). When $\overline{\mathrm{FF}}$ is high, a memory location is free in the SRAM to receive new data. No memory locations are free when FF is low and attempted writes to the FIFO are ignored.

Each time a word is written to the FIFO, the write pointer is incremented. From the time a word is read from the FIFO, the previous memory location is ready to be written in a minimum of three CLKA cycles. FF is low if fewer than two CLKA cycles have elapsed since the next memory-write location has been read. The second low-to-high transition on the $\overline{F F}$ synchronizing clock after the read sets the $\overline{\mathrm{FF}}$ high and data can be written in the following clock cycle.
A low-to-high transition on CLKA begins the first synchronization cycle of a read if the clock transition occurs at time $\mathrm{t}_{\mathrm{sk} 1}$, or greater, after the read. Otherwise, the subsequent clock cycle can be the first synchronization cycle (see Figure 10).

# SN74ABT3613 <br> $64 \times 36$ CLOCKED FIRST-IN, FIRST-OUT MEMORY WITH BUS MATCHING AND BYTE SWAPPING <br> SCBS128F - JULY 1992 - REVISED APRIL 1998 

## almost-empty flag ( $\overline{\mathrm{AE}}$ )

The FIFO $\overline{A E}$ flag is synchronized to the port clock that reads data from its array (CLKB). The almost-empty state is defined by the value of the $\overline{\mathrm{AF}}$ and $\overline{\mathrm{AE}}$ offset register (X). This register is loaded with one of four preset values during a device reset (see reset). An $\overline{\mathrm{AE}}$ flag is low when the FIFO contains X or fewer long words in memory and is high when the FIFO contains ( $\mathrm{X}+1$ ) or more long words.
Two low-to-high transitions of CLKB are required after a FIFO write for the $\overline{\mathrm{AE}}$ flag to reflect the new level of fill; therefore, the $\overline{A E}$ flag of a FIFO containing ( $X+1$ ) or more long words remains low if two CLKB cycles have not elapsed since the write that filled the memory to the $(X+1)$ level. An $\overline{\mathrm{AE}}$ flag is set high by the second low-to-high transition of CLKB after the FIFO write that fills memory to the $(X+1)$ level. A low-to-high transition of CLKB begins the first synchronization cycle if it occurs at time $\mathrm{t}_{\text {sk2 }}$, or greater, after the write that fills the FIFO to $(X+1)$ long words. Otherwise, the subsequent CLKB cycle can be the first synchronization cycle (see Figure 11).

## almost-full flag ( $\overline{\mathbf{A F})}$

The FIFO $\overline{\mathrm{AF}}$ flag is synchronized to the port clock that writes data to its array (CLKA). The almost-full state is defined by the value of the $\overline{\mathrm{AF}}$ and $\overline{\mathrm{AE}}$ offset register (X). This register is loaded with one of four preset values during a device reset (see reset). An $\overline{\mathrm{AF}}$ flag is low when the FIFO contains $(64-\mathrm{X}$ ) or more long words in memory and is high when the FIFO contains [64-(X+1)] or less long words.
Two low-to-high transitions of CLKA are required after a FIFO read for the $\overline{\mathrm{AF}}$ flag to reflect the new level of fill; therefore, the $\overline{\mathrm{AF}}$ flag of a FIFO containing $[64-(\mathrm{X}+1)]$ or fewer words remains low if two CLKA cycles have not elapsed since the read that reduced the number of long words in memory to $[64-(X+1)]$. An $\overline{\mathrm{AF}}$ flag is set high by the second low-to-high transition of CLKA after the FIFO read that reduces the number of long words in memory to $[64-(X+1)]$. A low-to-high transition of CLKA begins the first synchronization cycle if it occurs at time $t_{s k 2}$, or greater, after the read that reduces the number of long words in memory to [64-(X+1)]. Otherwise, the subsequent CLKA cycle can be the first synchronization cycle (see Figure 12).

## mailbox registers

Two 36 -bit bypass registers (mail1, mail2) are on board the SN74ABT3613 to pass command and control information between port A and port B without putting it in queue. A low-to-high transition on CLKA writes A0-A35 data to the mail1 register when a port-A write is selected by $\overline{C S A}, W / \bar{R} A$, and ENA, and MBA is high. A low-to-high transition on CLKB writes B0-B35 data to the mail2 register when a port-B write is selected by ( $\overline{\mathrm{CSB}}, \mathrm{W} / \overline{\mathrm{RB}}$, and ENB) and both SIZO and SIZ1 are high. Writing data to a mail register sets the corresponding flag ( $\overline{\mathrm{MBF1}}$ or $\overline{\mathrm{MBF} 2}$ ) low. Attempted writes to a mail register are ignored while the mail flag is low.
When the port-B data outputs (B0-B35) are active, the data on the bus comes from the FIFO output register when either one or both $\mathrm{SIZ1}$ and SIZO are low and from the mail1 register when both SIZ1 and SIZ0 are high. The mail1 register flag ( $\overline{\mathrm{MBF} 1}$ ) is set high by a rising CLKB edge when a port-B read is selected by $\overline{\mathrm{CSB}}, \mathrm{W} / \overline{\mathrm{RB}}$, and ENB, and both SIZ1 and SIZ0 are high. The mail2 register flag (MBF2) is set high by a rising CLKA edge when a port-A read is selected by $\overline{C S A}, W / \bar{R} A$, and $E N A$ and $M B A$ is high. The data in the mail register remains intact after it is read and changes only when new data is written to the register.

## WITH BUS MATCHING AND BYTE SWAPPING

SCBS128F - JULY 1992 - REVISED APRIL 1998

## dynamic bus sizing

The port-B bus can be configured in a 36 -bit long word, 18 -bit word, or 9 -bit byte format for data read from the FIFO. Word- and byte-size bus selections can utilize the most-significant bytes of the bus (big endian) or least-significant bytes of the bus (little endian). Port-B bus size can be changed dynamically and synchronous to CLKB to communicate with peripherals of various bus widths.
The levels applied to the port-B bus-size select (SIZO, SIZ1) inputs and the big-endian select ( $\overline{\mathrm{BE}}$ ) input are stored on each CLKB low-to-high transition. The stored port-B bus-size selection is implemented by the next rising edge on CLKB according to Figure 1.
Only 36-bit long-word data is written to or read from the FIFO memory on the SN74ABT3613. Bus-matching operations are done after data is read from the FIFO RAM. Port-B bus sizing does not apply to mail-register operations.

BYTE ORDER ON PORT A:

(a) LONG-WORD SIZE

| $\overline{\mathrm{BE}}$ | SIZ1 | SIZ0 |
| :---: | :---: | :---: |
| L | L | H |



1st: Read From FIFO
(b) WORD SIZE - BIG ENDIAN

| $\overline{B E}$ | SIZ1 | SIZ0 |
| :---: | :---: | :---: |
| $H$ | L | H |


(c) WORD SIZE - LITTLE ENDIAN

Figure 1. Dynamic Bus Sizing

| $\overline{B E}$ | SIZ1 | SIZ0 |
| :---: | :---: | :---: |
| $\mathbf{L}$ | $H$ | $L$ |



Figure 1. Dynamic Bus Sizing (Continued)

## bus-matching FIFO reads

Data is read from the FIFO RAM in 36-bit long-word increments. If a long-word bus size is implemented, the entire long word immediately shifts to the FIFO output register upon a read. If byte or word size is implemented on port B, only the first one or two bytes appear on the selected portion of the FIFO output register with the rest of the long word stored in auxiliary registers. In this case, subsequent FIFO reads with the same bus-size implementation output the rest of the long word to the FIFO output register in the order shown by Figure 1.
Each FIFO read with a new bus-size implementation automatically unloads data from the FIFO RAM to its output register and auxiliary registers. Implementing a new port-B bus size and performing a FIFO read before all bytes or words stored in the auxiliary registers have been read results in a loss of the unread data in these registers.

When reading data from FIFO in byte or word format, the unused B0-B35 outputs remain inactive but static, with the unused FIFO output register bits holding the last data value to decrease power consumption.

## port-B mail-register access

In addition to selecting port-B bus sizes for FIFO reads, the port-B bus-size select (SIZO, SIZ1) inputs also access the mail registers. When both SIZ0 and SIZ1 are high, the mail1 register is accessed for a port-B long-word read and the mail2 register is accessed for a port-B long-word write. The mail register is accessed immediately. Any bus-sizing operation that is underway is unaffected by the mail-register access. After the mail-register access is complete, the previous FIFO access can resume in the next CLKB cycle. The logic diagram in Figure 2 shows the previous bus-size selection is preserved when the mail registers are accessed from port B . A port- B bus size is implemented on each rising CLKB edge according to the states of SIZO_Q, SIZ1_Q, and BE_Q.


Figure 2. Logic Diagram for SIZO, SIZ1, and $\overline{\text { BE }}$ Register

## byte swapping

The byte-order arrangement of data read from the FIFO can be changed synchronous to the rising edge of CLKB. Byte-order swapping is not available for mail-register data. Four modes of byte-order swapping (including no swap) can be done with any data-port-size selection. The order of the bytes is rearranged within the long word, but the bit order within the bytes remains constant.
Byte arrangement is chosen by the port-B swap-select (SW0, SW1) inputs on a CLKB rising edge that reads a new long word from the FIFO. The byte order chosen on the first byte or first word of a new long-word read from the FIFO is maintained until the entire long word is transferred, regardless of the SW0 and SW1 states during subsequent reads. Figure 3 is an example of the byte-order swapping available for long-word reads. Performing a byte swap and bus size simultaneously for a FIFO read rearranges the bytes as shown in Figure 3, then outputs the bytes as shown in Figure 1.

(a) NO SWAP

(b) BYTE SWAP

(c) WORD SWAP

| SW1 | SW0 |
| :---: | :---: |
| $H$ | $H$ |


(d) BYTE-WORD SWAP

Figure 3. Byte Swapping for FIFO Reads (Long-Word Size Example)

# $64 \times 36$ CLOCKED FIRST-IN, FIRST-OUT MEMORY WITH BUS MATCHING AND BYTE SWAPPING <br> SCBS128F - JULY 1992 - REVISED APRIL 1998 

parity checking
The port-A data inputs (A0-A35) and port-B data inputs (B0-B35) each have four parity trees to check the parity of incoming (or outgoing) data. A parity failure on one or more bytes of the port-A data bus is reported by a low level on the port-A parity error flag ( $\overline{\mathrm{PEFA}})$. A parity failure on one or more bytes of the port-B data inputs that are valid for the bus-size implementation is reported by a low level on the port-B parity-error flag ( $\overline{\mathrm{PEFB}}$ ). Odd or even parity checking can be selected and the parity-error flags can be ignored if this feature is not desired.
Parity status is checked on each input bus according to the level of the odd/even parity (ODD/EVEN) select input. A parity error on one or more valid bytes of a port is reported by a low level on the corresponding port parity-error flag ( $\overline{\mathrm{PEFA}}, \overline{\mathrm{PEFB}}$ ) output. Port-A bytes are arranged as A0-A8, A9-A17, A18-A26, and A27-A35. Port-B bytes are arranged as B0-B8, B9-B17, B18-B26, and B27-B35, and its valid bytes are those used in a port- B bus-size implementation. When odd/even parity is selected, a port parity-error flag ( $\overline{\mathrm{PEFA}}, \overline{\mathrm{PEFB}}$ ) is low if any valid byte on the port has an odd/even number of low levels applied to the bits.

The four parity trees used to check the A0-A35 inputs are shared by the mail2 register when parity generation is selected for port-A reads (PGA = high). When a port-A read from the mail2 register with parity generation is selected with CSA low, ENA high, W/RA low, MBA high, and PGA high, PEFA is held high, regardless of the levels applied to the A0-A35 inputs. Likewise, the parity trees used to check the B0-B35 inputs are shared by the mail1 register when parity generation is selected for port-B reads ( $\mathrm{PGB}=$ high). When a port- B read from the mail1 register with parity generation is selected with CSB low, ENB high, W/ $\overline{\mathrm{RB}}$ low, both SIZ0 and SIZ1 high, and PGB high, $\overline{\text { PEFB }}$ is held high, regardless of the levels applied to the B0-B35 inputs.

## parity generation

A high level on the port-A parity-generate select (PGA) or port-B parity-generate select (PGB) enables the SN74ABT3613 to generate parity bits for port reads from a FIFO or mailbox register. Port-A bytes are arranged as A0-A8, A9-A17, A18-A26, and A27-A35, with the most-significant bit of each byte used as the parity bit. Port-B bytes are arranged as B0-B8, B9-B17, B18-B26, and B27-B35 with the most-significant bit of each byte used as the parity bit. A write to a FIFO or mail register stores the levels applied to all nine inputs of a byte, regardless of the state of the parity-generate select (PGA, PGB) inputs. When data is read from a port with parity generation selected, the lower eight bits of each byte are used to generate a parity bit according to the level on the ODD/EVEN select. The generated parity bits are substituted for the levels originally written to the most-significant bits of each byte as the word is read to the data outputs.
Parity bits for FIFO data are generated after the data is read from SRAM and before the data is written to the output register. The port-A parity-generate select (PGA) and odd/even parity select (ODD/EVEN) have setupand hold-time constraints to the port-A clock (CLKA) and the port-B parity-generate select (PGB) and ODD/EVEN select have setup- and hold-time constraints to the port-B clock (CLKB). These timing constraints apply only for a rising clock edge used to read a new long word to the FIFO output register.

The circuit used to generate parity for the mail1 data is shared by the port-B bus (B0-B35) to check parity. The circuit used to generate parity for the mail2 data is shared by the port-A bus (A0-A35) to check parity. The shared parity trees of a port are used to generate parity bits for the data in a mail register when the port-chip select ( $\overline{\mathrm{CSA}}$, $\overline{C S B}$ ) is low, enable (ENA, ENB) is high, and write/read select (W/RA, W/RB) input is low, the mail register is selected (MBA is high for port A; both SIZ0 and SIZ1 are high for port B), and port parity-generate select (PGA, $\mathrm{PGB})$ is high. Generating parity for mail-register data does not change the contents of the register.


Figure 4. Device Reset Loading the X Register With the Value of Eight

$\dagger$ Written to the FIFO
Figure 5. FIFO Write Cycle

$\dagger$ SIZ0 $=\mathrm{H}$ and SIZ1 $=\mathrm{H}$ selects the mail1 register for output on B0-B35.
$\ddagger$ Data read from the FIFO

DATA SWAP FOR FIFO LONG-WORD READS

| FIFO-DATA WRITE |  |  |  | SWAP MODE | FIFO-DATA READ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A35-A27 | A26-A18 | A17-A9 | A8-A0 | SW1 | SW0 | B35-B27 | B26-B18 | B17-B9 | B8-B0 |
| A | B | C | D | L | L | A | B | C | D |
| A | B | C | D | L | H | D | C | B | A |
| A | B | C | D | H | L | C | D | A | B |
| A | B | C | D | H | H | B | A | D | C |

Figure 6. FIFO Long-Word Read Cycle

## SN74ABT3613 $64 \times 36$ CLOCKED FIRST-IN, FIRST-OUT MEMORY WITH BUS MATCHING AND BYTE SWAPPING


$\dagger$ SIZO $=\mathrm{H}$ and SIZ1 $=\mathrm{H}$ selects the mail1 register for output on B0-B35.
$\ddagger$ Unused word B0-B17 or B18-B35 holds last FIFO output-register data for word-size reads.

| FIFO-DATA WRITE |  |  |  | SWAP MODE |  | $\begin{aligned} & \text { READ } \\ & \text { NO. } \end{aligned}$ | FIFO-DATA READ |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | BIG ENDIAN | LITTLE ENDIAN |  |
| A35-A27 | A26-A18 | A17-A9 | A8-A0 |  |  | SW1 | SW0 | B35-B27 | B26-B18 | B17-B9 | B8-B0 |
| A | B | C | D | L | L |  | 1 | A | B | C | D |
|  |  |  |  |  |  |  | 2 | C | D | A | B |
| A | B | C | D | L | H | 1 | D | C | B | A |
|  |  |  |  |  |  | 2 | B | A | D | C |
| A | B | C | D | H | L | 1 | C | D | A | B |
|  |  |  |  |  |  | 2 | A | B | C | D |
| A | B | C | D | H | H | 1 | B | A | D | C |
|  |  |  |  |  |  | 2 | D | C | B | A |

Figure 7. FIFO-Word Read Cycle

$\dagger$ SIZO $=\mathrm{H}$ and SIZ1 $=\mathrm{H}$ selects the mail1 register for output on B0 - B35.
NOTE A: Unused bytes hold the last FIFO output-register data for byte-size reads.
Figure 8. FIFO-Byte Read Cycle

DATA SWAP FOR FIFO-BYTE READS

|  |  |  |  |  |  |  | FIFO-D | READ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | FIFO-DATA | WRITE |  | SWAP | MODE | READ NO. | $\begin{gathered} \text { BIG } \\ \text { ENDIAN } \end{gathered}$ | LITTLE <br> ENDIAN |
| A35-A27 | A26-A18 | A17-A9 | A8-A0 | SW1 | SW0 |  | B35-B27 | B8-B0 |
|  |  |  |  |  |  | 1 | A | D |
|  |  |  |  |  |  | 2 | B | C |
|  |  | C | D | L | L | 3 | C | B |
|  |  |  |  |  |  | 4 | D | A |
|  |  |  |  |  |  | 1 | D | A |
| A | B | C | D |  | h | 2 | C | B |
|  |  |  |  |  |  | 3 | B | C |
|  |  |  |  |  |  | 4 | A | D |
|  |  |  |  |  |  | 1 | C | B |
| A | B | C | D | H |  | 2 | D | A |
|  |  |  |  |  |  | 3 | A | D |
|  |  |  |  |  |  | 4 | B | C |
|  |  |  |  |  |  | 1 | B | C |
| A | B |  |  |  |  | 2 | A | D |
|  |  |  |  |  |  | 3 | D | A |
|  |  |  |  |  |  | 4 | C | B |

Figure 8. FIFO-Byte Read Cycle (Continued)

$\dagger_{t_{\text {sk } 1}}$ is the minimum time between a rising CLKA edge and a rising CLKB edge for $\overline{E F}$ to transition high in the next CLKB cycle. If the time between the rising CLKA edge and rising CLKB edge is less than $\mathrm{t}_{\mathrm{sk} 1}$, the transition of $\overline{\mathrm{EF}}$ high may occur one CLKB cycle later than shown. NOTE A: Port-B size of long word is selected for the FIFO read by $\mathrm{SIZ1}=\mathrm{L}, \mathrm{SIZO}=\mathrm{L}$. If port-B size is word or byte, $\overline{\mathrm{EF}}$ is set low by the last word or byte read from the FIFO, respectively.

Figure 9. EF-Flag Timing and First Data Read When the FIFO Is Empty

$\dagger t_{\text {sk } 1}$ is the minimum time between a rising CLKB edge and a rising CLKA edge for $\overline{F F}$ to transition high in the next CLKA cycle. If the time between the rising CLKB edge and rising CLKA edge is less than tsk1, FF may transition high one CLKA cycle later than shown.
NOTE A: Port-B size of long word is selected for the FIFO read by $\mathrm{SIZ1}=\mathrm{L}, \mathrm{SIZO}=\mathrm{L}$. If port-B size is word or byte, $\mathrm{t}_{\mathrm{sk} 1}$ is referenced from the rising CLKB edge that reads the first word or byte of the long word, respectively.

Figure 10. FF-Flag Timing and First Available Write When the FIFO Is Full

$\dagger_{t_{\text {sk }} 2}$ is the minimum time between a rising CLKA edge and a rising CLKB edge for $\overline{A E}$ to transition high in the next CLKB cycle. If the time between the rising CLKA edge and rising CLKB edge is less than tsk2, $\overline{A E}$ may transition high one CLKB cycle later than shown.

## NOTES: A. FIFO write ( $\overline{C S A}=L, W / \bar{R} A=H, M B A=L$ ), FIFO read ( $\overline{C S B}=L, W / \bar{R} B=L, M B B=L$ )

B. Port-B size of long word is selected for FIFO read by $\mathrm{SIZ1}=\mathrm{L}, \mathrm{SIZO}=\mathrm{L}$. If port-B size is word or byte, $\mathrm{t}_{\text {sk2 }}$ is referenced to the first word or byte read of the long word, respectively.

Figure 11. $\overline{\mathrm{AE}}$ When the FIFO Is Almost Empty

$\ddagger \mathrm{t}_{\text {sk }}$ is the minimum time between a rising CLKA edge and a rising CLKB edge for $\overline{\mathrm{AF}}$ to transition high in the next CLKA cycle. If the time between the rising CLKA edge and rising CLKB edge is less than $t_{s k 2}, \overline{\mathrm{AF}}$ may transition high one CLKB cycle later than shown.
NOTES: A. FIFO write ( $\overline{C S A}=L, W / \bar{R} A=H, M B A=L$ ), FIFO read ( $\overline{C S B}=L, W / \bar{R} B=L, M B B=L$ )
B. Port- B size of long word is selected for FIFO read by $\mathrm{SIZ1}=\mathrm{L}, \mathrm{SIZO}=\mathrm{L}$. If port-B size is word or byte, $\mathrm{t}_{\text {sk2 }}$ is referenced from the first word or byte read of the long word, respectively.

Figure 12. $\overline{\mathrm{AF}}$ When the FIFO Is Almost Full


NOTE A: Port-B parity generation off ( $\mathrm{PGB}=\mathrm{L}$ )
Figure 13. Mail1 Register and MBF1 Flag


NOTE A: Port-A parity generation off $(P G A=L)$
Figure 14. Mail2 Register and MBF2 Flag


NOTE A: $\overline{\mathrm{CSA}}=\mathrm{L}$ and $\mathrm{ENA}=\mathrm{H}$
Figure 15. ODD/ $\overline{\text { EVEN }}, \mathrm{W} / \overline{\mathrm{R}} \mathrm{A}, \mathrm{MBA}$, and PGA to $\overline{\text { PEFA }}$


NOTE A: $\overline{\mathrm{CSB}}=\mathrm{L}$ and $\mathrm{ENB}=\mathrm{H}$
Figure 16. ODD/EVEN, W/ $\bar{R} B$, SIZ1, SIZ0, and PGB to $\overline{\text { PEFB }}$


NOTE A: ENA $=\mathrm{H}$
Figure 17. Parity Generation When Reading From the Mail2 Register


Figure 18. Parity Generation When Reading From the Mail1 Register

## SN74ABT3613 $64 \times 36$ CLOCKED FIRST-IN, FIRST-OUT MEMORY WITH BUS MATCHING AND BYTE SWAPPING

## absolute maximum ratings over operating free-air temperature range (unless otherwise noted) $\dagger$

> Supply voltage range, $\mathrm{V}_{\mathrm{CC}}$ -0.5 V to 7 V

> Package thermal impedance, $\theta_{\mathrm{JA}}$ (see Note 2): PCB package . ...................................... $28^{\circ} \mathrm{C} / \mathrm{W}$
> PQ package ........................................ $46^{\circ} \mathrm{C} / \mathrm{W}$
$\dagger$ Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. These are stress ratings only, and
functional operation of the device at these or any other conditions beyond those indicated under "recommended operating conditions" is not
implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.
NOTES: 1. The input and output voltage ratings may be exceeded provided the input and output current ratings are observed.
2. The package thermal impedance is calculated in accordance with JESD 51.
recommended operating conditions

|  |  | MIN | MAX |
| :--- | :--- | ---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | UnPIT |  |  |
| $\mathrm{V}_{\mathrm{IH}}$ | High-level input voltage | 4.5 | 5.5 |
| $\mathrm{~V}_{\mathrm{IL}}$ | Low-level input voltage | 2 | V |
| $\mathrm{I}_{\mathrm{OH}}$ | High-level output current | V |  |
| $\mathrm{I}_{\mathrm{OL}}$ | Low-level output current | 0.8 | V |
| $\mathrm{~T}_{\mathrm{A}}$ | Operating free-air temperature | -4 | mA |

## electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER | TEST CONDITIONS |  |  |  | MIN | TYP $\ddagger$ MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{IOH}=-4 \mathrm{~mA}$ |  |  | 2.4 |  | V |
| $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{l}^{\mathrm{OL}}=8 \mathrm{~mA}$ |  |  |  | 0.5 | V |
| I | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{I}}=\mathrm{V}_{\mathrm{CC}}$ or 0 |  |  |  | $\pm 50$ | $\mu \mathrm{A}$ |
| IOZ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=\mathrm{V}_{\mathrm{CC}}$ or 0 |  |  |  | $\pm 50$ | $\mu \mathrm{A}$ |
| ICC | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{l}=0 \mathrm{~mA}$, | $\mathrm{V}_{\mathrm{I}}=\mathrm{V}_{\mathrm{CC}}$ or GND | Outputs high |  | 60 | mA |
|  |  |  |  | Outputs low |  | 130 |  |
|  |  |  |  | Outputs disabled |  | 60 |  |
| $\mathrm{C}_{\mathrm{i}}$ | $\mathrm{V}_{1}=0$, | $\mathrm{f}=1 \mathrm{MHz}$ |  |  |  | 4 | pF |
| $\mathrm{C}_{0}$ | $\mathrm{V}_{\mathrm{O}}=0$, | $\mathrm{f}=1 \mathrm{MHz}$ |  |  |  | 8 | pF |

$\ddagger$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
timing requirements over recommended ranges of supply voltage and operating free-air temperature (see Figures 4 through 19)

|  |  | 'ABT3613-15 |  | 'ABT3613-20 |  | 'ABT3613-30 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |
| $\mathrm{f}_{\text {clock }}$ | Clock frequency, CLKA or CLKB |  | 66.7 |  | 50 |  | 33.4 | MHz |
| $\mathrm{t}_{\mathrm{c}}$ | Clock cycle time, CLKA or CLKB | 15 |  | 20 |  | 30 |  | ns |
| $\mathrm{t}_{\mathrm{w} \text { (CLKH) }}$ | Pulse duration, CLKA and CLKB high | 6 |  | 8 |  | 12 |  | ns |
| $\mathrm{t}_{\mathrm{W} \text { (CLKL) }}$ | Pulse duration, CLKA and CLKB low | 6 |  | 8 |  | 12 |  | ns |
| $\mathrm{t}_{\text {su }}(\mathrm{D})$ | Setup time, A0-A35 before CLKA $\uparrow$ and B0-B35 before CLKB $\uparrow$ | 4 |  | 5 |  | 6 |  | ns |
| $\mathrm{t}_{\text {su (EN) }}$ | Setup time, $\overline{\mathrm{CSA}}, \mathrm{W} / \overline{\mathrm{R}} \mathrm{A}, \mathrm{ENA}$, and MBA before CLKA $\uparrow$; $\overline{C S B}, W / \bar{R} B$, and $E N B$ before CLKB $\uparrow$ | 5 |  | 5 |  | 6 |  | ns |
| $\left.\mathrm{t}_{\text {su( }} \mathrm{SZ}\right)$ | Setup time, SIZO, SIZ1, and $\overline{\text { BE }}$ before CLKB $\uparrow$ | 4 |  | 5 |  | 6 |  | ns |
| $\mathrm{t}_{\text {su }}(\mathrm{SW})$ | Setup time, SW0 and SW1 before CLKB $\uparrow$ | 5 |  | 7 |  | 8 |  | ns |
| $\mathrm{t}_{\mathrm{su}}(\mathrm{PG})$ | Setup time, ODD/ $\overline{\text { EVEN }}$ and PGB before CLKB $\uparrow \dagger$ | 4 |  | 5 |  | 6 |  | ns |
| $\mathrm{t}_{\text {su }}(\mathrm{RS}$ ) | Setup time, $\overline{\text { RST }}$ low before CLKA $\uparrow$ or CLKB $\uparrow \ddagger$ | 5 |  | 6 |  | 7 |  | ns |
| $\mathrm{t}_{\text {su }}(\mathrm{FS})$ | Setup time, FS0 and FS1 before $\overline{\text { RST }}$ high | 5 |  | 6 |  | 7 |  | ns |
| th(D) | Hold time, A0-A35 after CLKA $\uparrow$ and B0-B35 after CLKB $\uparrow$ | 1 |  | 1 |  | 1 |  | ns |
| th(EN) | Hold time, $\overline{C S A}, W / \bar{R} A, ~ E N A, ~ a n d ~ M B A ~ a f t e r ~ C L K A \uparrow ; ~ ;$ $\overline{C S B}, \mathrm{~W} / \overline{\mathrm{RB}}$, and ENB after CLKB $\uparrow$ | 1 |  | 1 |  | 1 |  | ns |
| $\mathrm{th}_{\mathrm{h}}(\mathrm{SZ})$ | Hold time, SIZ0, SIZ1, and $\overline{\mathrm{BE}}$ after CLKB $\uparrow$ | 2 |  | 2 |  | 2 |  | ns |
| $\mathrm{th}_{\mathrm{h}}^{(S W)}$ | Hold time, SW0 and SW1 after CLKB $\uparrow$ | 0 |  | 0 |  | 0 |  | ns |
| $\operatorname{th}(\mathrm{PG})$ | Hold time, ODD/EVEN and PGB after CLKB $\uparrow \dagger$ | 0 |  | 0 |  | 0 |  | ns |
| th(RS) | Hold time, $\overline{\text { RST }}$ low after CLKA $\uparrow$ or CLKB $\uparrow \ddagger$ | 5 |  | 6 |  | 7 |  | ns |
| th(FS) | Hold time, FS0 and FS1 after $\overline{\text { RST }}$ high | 4 |  | 4 |  | 4 |  | ns |
| $\mathrm{t}_{\text {sk } 1}$ § | Skew time between CLKA $\uparrow$ and CLKB $\uparrow$ for $\overline{\mathrm{EF}}$ and $\overline{\mathrm{FF}}$ | 8 |  | 8 |  | 10 |  | ns |
| $\mathrm{t}_{\text {sk2 }}{ }^{\text {§ }}$ | Skew time between CLKA $\uparrow$ and CLKB $\uparrow$ for $\overline{\mathrm{AE}}$ and $\overline{\mathrm{AF}}$ | 9 |  | 16 |  | 20 |  | ns |

$\dagger$ Applies only for a clock edge that does a FIFO read
$\ddagger$ Requirement to count the clock edge as one of at least four needed to reset a FIFO
§ Skew time is not a timing constraint for proper device operation and is included only to illustrate the timing relationship between CLKA cycle and CLKB cycle.

## SN74ABT3613 <br> $64 \times 36$ CLOCKED FIRST-IN, FIRST-OUT MEMORY WITH BUS MATCHING AND BYTE SWAPPING

switching characteristics over recommended ranges of supply voltage and operating free-air temperature, $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ (see Figures 4 through 19)

| PARAMETER |  | 'ABT3613-15 |  | 'ABT3613-20 |  | 'ABT3613-30 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |
| $f_{\text {max }}$ |  | 66.7 |  | 50 |  | 33.4 |  | MHz |
| $\mathrm{t}_{\mathrm{a}}$ | Access time, CLKA $\uparrow$ to A0-A35 and CLKB $\uparrow$ to B0-B35 | 2 | 10 | 2 | 12 | 2 | 15 | ns |
| $t_{\text {pd( }}(\mathrm{C}-\mathrm{FF})$ | Propagation delay time, CLKA $\uparrow$ to $\overline{\mathrm{FF}}$ | 2 | 10 | 2 | 12 | 2 | 15 | ns |
| $t_{\text {pd }}(\mathrm{C}-\mathrm{EF})$ | Propagation delay time, CLKB $\uparrow$ to $\overline{\mathrm{EF}}$ | 2 | 10 | 2 | 12 | 2 | 15 | ns |
| $t_{\text {pd }}(\mathrm{C}-\mathrm{AE})$ | Propagation delay time, CLKB $\uparrow$ to $\overline{\mathrm{AE}}$ | 2 | 10 | 2 | 12 | 2 | 15 | ns |
| $t_{\text {pd }}(\mathrm{C}-\mathrm{AF})$ | Propagation delay time, CLKA $\uparrow$ to $\overline{\mathrm{AF}}$ | 2 | 10 | 2 | 12 | 2 | 15 | ns |
| ${ }_{\text {tpd(C-MF) }}$ | Propagation delay time, CLKA to $\overline{\mathrm{MBF} 1}$ low or $\overline{\text { MBF2 }}$ high and CLKB to $\overline{\text { MBF2 }}$ low or MBF1 high | 1 | 9 | 1 | 12 | 1 | 15 | ns |
| $t_{\text {tpd(C-MR }}$ | Propagation delay time, CLKA $\uparrow$ to $\mathrm{B} 0-\mathrm{B} 35 \dagger$ and CLKB $\uparrow$ to A0-A35 $\ddagger$ | 3 | 11 | 3 | 12 | 3 | 15 | ns |
| $t_{\text {pd }}(\mathrm{C}-\mathrm{PE})^{\text {§ }}$ | Propagation delay time, CLKB $\uparrow$ to $\overline{\text { PEFB }}$ | 2 | 11 | 2 | 12 | 2 | 13 | ns |
| $t_{\text {pd }}(\mathrm{M}-\mathrm{DV})$ | Propagation delay time, SIZ1, SIZ0 to B0-B35 valid | 1 | 11 | 1 | 11.5 | 1 | 12 | ns |
| ${ }^{\text {tpd }}$ (D-PE) | Propagation delay time, <br> A0-A35 valid to PEFA valid; B0-B35 valid to $\overline{\text { PEFB }}$ valid | 3 | 10 | 3 | 11 | 3 | 13 | ns |
| tpd(O-PE) | Propagation delay time, ODD/ $\overline{\text { EVEN }}$ to $\overline{\text { PEFA }}$ and $\overline{\text { PEFB }}$ | 3 | 11 | 3 | 12 | 3 | 14 | ns |
| $t_{\text {pd }}(\mathrm{O}-\mathrm{PB})^{\text {a }}$ | Propagation delay time, ODD/EVEN to parity bits <br> (A8, A17, A26, A35) and (B8, B17, B26, B35) | 2 | 12 | 2 | 13 | 2 | 15 | ns |
| tpd(E-PE) | Propagation delay time, $\overline{\mathrm{CSA}}, \mathrm{ENA}, \mathrm{W} / \overline{\mathrm{R}} \mathrm{A}, \mathrm{MBA}$, or PGA to $\overline{\text { PEFA; }}$; $\overline{C S B}, ~ E N B, W / \bar{R} B, S I Z 1, S I Z 0$, or PGB to $\overline{\text { PEFB }}$ | 1 | 11 | 1 | 12 | 1 | 14 | ns |
| $t_{\text {pd }}(\mathrm{E}-\mathrm{PB})^{\text {a }}$ | Propagation delay time, $\overline{\mathrm{CSA}}, \mathrm{ENA}, \mathrm{W} / \overline{\mathrm{R}} \mathrm{A}, \mathrm{MBA}$, or PGA to parity bits (A8, A17, A26, A35); $\overline{\mathrm{CSB}}, \mathrm{ENB}, \mathrm{W} / \overline{\mathrm{R}} \mathrm{B}$, SIZ1, SIZ0, or PGB to parity bits (B8, B17, B26, B35) | 3 | 12 | 3 | 13 | 3 | 14 | ns |
| $\mathrm{t}_{\mathrm{pd}}(\mathrm{R}-\mathrm{F})$ | Propagation delay time, <br> $\overline{\mathrm{RST}}$ to $\overline{\mathrm{AE}}, \overline{\mathrm{EF}}$ low and $\overline{\mathrm{AF}}, \overline{\mathrm{MBF}}, \overline{\mathrm{MBF} 2}$ high | 1 | 15 | 1 | 20 | 1 | 25 | ns |
| ten | Enable time, $\overline{\mathrm{CSA}}$ and W/ $\overline{\mathrm{R}}$ A low to A0-A35 active and $\overline{C S B}$ low and $W / \bar{R} B$ high to $B 0-B 35$ active | 2 | 10 | 2 | 12 | 2 | 14 | ns |
| $t_{\text {dis }}$ | Disable time, $\overline{\mathrm{CSA}}$ or $\mathrm{W} / \overline{\mathrm{R}} \mathrm{A}$ high to A0-A35 at high impedance and $\overline{\mathrm{CSB}}$ high or W/RB low to B0-B35 at high impedance | 1 | 8 | 1 | 9 | 1 | 11 | ns |

$\dagger$ Writing data to the mail1 register when the B0-B35 outputs are active and SIZ1 and SIZ0 are high
$\ddagger$ Writing data to the mail2 register when the A0-A35 outputs are active and MBA is high
§ Applies only when a new port-B bus size is implemented by the rising CLKB edge
I Applies only when reading data from a mail register

PARAMETER MEASUREMENT INFORMATION


LOAD CIRCUIT


VOLTAGE WAVEFORMS
ENABLE AND DISABLE TIMES


VOLTAGE WAVEFORMS
PROPAGATION DELAY TIMES

NOTES: A. Includes probe and jig capacitance
B. tPZL and tPZH are the same as ten
C. $t_{P L Z}$ and $t_{P H Z}$ are the same as $t_{\text {dis }}$

Figure 19. Load Circuit and Voltage Waveforms

## TYPICAL CHARACTERISTICS



Figure 20

## PACKAGING INFORMATION

| Orderable Device | Status $^{(1)}$ | Package <br> Type | Package <br> Drawing | Pins Package <br> Qty | Eco Plan ${ }^{(2)}$ | Lead/Ball Finish | MSL Peak Temp ${ }^{(3)}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SN74ABT3613-15PCB | OBSOLETE | HLQFP | PCB | 120 | TBD | Call TI | Call TI |
| SN74ABT3613-15PQ | OBSOLETE | BQFP | PQ | 132 | TBD | Call TI | Call TI |
| SN74ABT3613-20PCB | OBSOLETE | HLQFP | PCB | 120 | TBD | Call TI | Call TI |
| SN74ABT3613-20PQ | OBSOLETE | BQFP | PQ | 132 | TBD | Call TI | Call TI |
| SN74ABT3613-30PCB | OBSOLETE | HLQFP | PCB | 120 | TBD | Call TI | Call TI |
| SN74ABT3613-30PQ | OBSOLETE | BQFP | PQ | 132 | TBD | Call TI | Call TI |

${ }^{(1)}$ The marketing status values are defined as follows:
ACTIVE: Product device recommended for new designs.
LIFEBUY: TI has announced that the device will be discontinued, and a lifetime-buy period is in effect.
NRND: Not recommended for new designs. Device is in production to support existing customers, but TI does not recommend using this part in a new design.
PREVIEW: Device has been announced but is not in production. Samples may or may not be available.
OBSOLETE: TI has discontinued the production of the device.
(2) Eco Plan - The planned eco-friendly classification: Pb-Free (RoHS) or Green (RoHS \& no $\mathrm{Sb} / \mathrm{Br}$ ) - please check http://www.ti.com/productcontent for the latest availability information and additional product content details.
TBD: The Pb-Free/Green conversion plan has not been defined.
Pb-Free (RoHS): TI's terms "Lead-Free" or "Pb-Free" mean semiconductor products that are compatible with the current RoHS requirements for all 6 substances, including the requirement that lead not exceed $0.1 \%$ by weight in homogeneous materials. Where designed to be soldered at high temperatures, TI Pb -Free products are suitable for use in specified lead-free processes.
Green (RoHS \& no Sb/Br): TI defines "Green" to mean Pb-Free (RoHS compatible), and free of Bromine (Br) and Antimony (Sb) based flame retardants ( Br or Sb do not exceed $0.1 \%$ by weight in homogeneous material)
${ }^{(3)}$ MSL, Peak Temp. -- The Moisture Sensitivity Level rating according to the JEDEC industry standard classifications, and peak solder temperature.

Important Information and Disclaimer:The information provided on this page represents Tl's knowledge and belief as of the date that it is provided. Tl bases its knowledge and belief on information provided by third parties, and makes no representation or warranty as to the accuracy of such information. Efforts are underway to better integrate information from third parties. Tl has taken and continues to take reasonable steps to provide representative and accurate information but may not have conducted destructive testing or chemical analysis on incoming materials and chemicals. TI and TI suppliers consider certain information to be proprietary, and thus CAS numbers and other limited information may not be available for release.

In no event shall Tl's liability arising out of such information exceed the total purchase price of the Tl part(s) at issue in this document sold by TI to Customer on an annual basis.


NOTES: A. All linear dimensions are in inches (millimeters).
B. This drawing is subject to change without notice.
C. Falls within JEDEC MO-069


NOTES: A. All linear dimensions are in millimeters.
B. This drawing is subject to change without notice.
C. Thermally enhanced molded plastic package with a heat slug (HSL)
D. Falls within JEDEC MS-026

## IMPORTANT NOTICE

Texas Instruments Incorporated and its subsidiaries (TI) reserve the right to make corrections, modifications, enhancements, improvements, and other changes to its products and services at any time and to discontinue any product or service without notice. Customers should obtain the latest relevant information before placing orders and should verify that such information is current and complete. All products are sold subject to Tl's terms and conditions of sale supplied at the time of order acknowledgment.

TI warrants performance of its hardware products to the specifications applicable at the time of sale in accordance with Tl's standard warranty. Testing and other quality control techniques are used to the extent TI deems necessary to support this warranty. Except where mandated by government requirements, testing of all parameters of each product is not necessarily performed.

TI assumes no liability for applications assistance or customer product design. Customers are responsible for their products and applications using TI components. To minimize the risks associated with customer products and applications, customers should provide adequate design and operating safeguards.

TI does not warrant or represent that any license, either express or implied, is granted under any TI patent right, copyright, mask work right, or other TI intellectual property right relating to any combination, machine, or process in which TI products or services are used. Information published by TI regarding third-party products or services does not constitute a license from TI to use such products or services or a warranty or endorsement thereof. Use of such information may require a license from a third party under the patents or other intellectual property of the third party, or a license from TI under the patents or other intellectual property of TI .

Reproduction of information in TI data books or data sheets is permissible only if reproduction is without alteration and is accompanied by all associated warranties, conditions, limitations, and notices. Reproduction of this information with alteration is an unfair and deceptive business practice. Tl is not responsible or liable for such altered documentation.

Resale of Tl products or services with statements different from or beyond the parameters stated by TI for that product or service voids all express and any implied warranties for the associated TI product or service and is an unfair and deceptive business practice. Tl is not responsible or liable for any such statements.

Following are URLs where you can obtain information on other Texas Instruments products and application solutions:

## Products

## Applications

| Amplifiers | amplifier.ti.com | Audio | www.ti.com/audio |
| :--- | :--- | :--- | :--- |
| Data Converters | dataconverter.ti.com | Automotive | www.ti.com/automotive |
| DSP | dsp.ti.com | Broadband | www.ti.com/broadband |
| Interface | interface.ti.com | Digital Control | www.ti.com/digitalcontrol |
| Logic | logic.ti.com | Military | www.ti.com/military |
| Power Mgmt | power.ti.com | Optical Networking | www.ti.com/opticalnetwork |
| Microcontrollers | microcontroller.ti.com | Security | www.ti.com/security |
|  |  | Telephony | www.ti.com/telephony |
|  |  | Video \& Imaging | www.ti.com/video |
|  |  | Wireless | www.ti.com/wireless |

Mailing Address: Texas Instruments<br>Post Office Box 655303 Dallas, Texas 75265

Copyright © 2005, Texas Instruments Incorporated

